import { BasicColumn, FormSchema } from '/@/components/Table';
import { h } from 'vue';
import { Tag } from 'ant-design-vue';
// 查询条件:卡号stid(模糊查询) 姓名name(模糊查询)，身份证号:idcard(模糊查询） 一卡通账户 account 激活时间 rtime  (时间段股查询）卡状态state(1正常2作废卡-1挂失卡 0 2白名单
// 视图字段:序号idx、卡号stid,硬件序号cid.name姓名 stime有效期开始时间,etime有效期结束时间 state状态idCard身份证号 account--卡通账户,ritime激活时间
export const columns: BasicColumn[] = [
  // {
  //   title: '索引',
  //   dataIndex: 'idx',
  //   width: 120,
  //   align: 'center',
  // },
  {
    title: '学生姓名',
    dataIndex: 'name',
    width: 120,
    align: 'center',
  },
  {
    title: '学生卡号',
    dataIndex: 'stid',
    align: 'center',
    width: 120,
  },
  {
    title: '卡号硬件ID',
    dataIndex: 'cid',
    align: 'center',
    width: 120,
  },
  {
    title: '一卡通账户',
    dataIndex: 'account',
    align: 'center',
    width: 120,
  },
  {
    title: '身份证号',
    dataIndex: 'idcard',
    align: 'center',
    width: 180,
  },
  {
    title: '注册时间',
    dataIndex: 'rtime',
    align: 'center',
    width: 180,
  },
  {
    title: '生效时间',
    dataIndex: 'stime',
    align: 'center',
    width: 180,
  },
  {
    title: '失效时间',
    dataIndex: 'etime',
    align: 'center',
    width: 180,
  },
  {
    title: '当前状态',
    dataIndex: 'state',
    align: 'center',
    width: 120,
    customRender: ({ text }) => {
      return h(Tag, { color: text == 1 ? 'green' : text == -2 ? 'orange' : text == 2 ? 'red' : 'gray' }, () =>
        text == 1 ? '正常卡' : text == -2 ? '挂失卡' : text == 2 ? '黑名单' : text == -1 ? '无效卡' : text == 0 ? '特殊卡' : '未知'
      );
    },
  },
];

export const searchFormSchema: FormSchema[] = [
  {
    field: 'name',
    label: '学生姓名',
    component: 'Input',
    colProps: { span: 6 },
  },
  {
    field: 'stid',
    label: '学生卡号',
    component: 'Input',
    colProps: { span: 6 },
  },
  {
    field: 'account',
    label: '一卡通账户',
    component: 'InputNumber',
    componentProps: {
      controls: false,
      placeholder: '请输入',
    },
    colProps: { span: 6 },
  },
  {
    field: 'rtime',
    label: '生效时间',
    component: 'RangePicker',
    colProps: { span: 6 },
    componentProps: {
      //是否显示时间
      showTime: true,
      //日期格式化
      format: 'YYYY-MM-DD HH:mm:ss',
      valueFormat: 'YYYY-MM-DD HH:mm:ss',
      //范围文本描述用集合
      placeholder: ['请选择开始日期时间', '请选择结束日期时间'],
    },
  },
  {
    field: 'state',
    label: '状态',
    component: 'RadioGroup',
    componentProps: {
      //options里面由一个一个的radio组成,支持disabled禁用
      options: [
        { label: '正常卡', value: 1 },
        { label: '特殊卡', value: 0 },
        { label: '黑名单', value: 2 },
        { label: '无效卡', value: -1 },
        { label: '挂失卡', value: -2 },
      ],
    },
    colProps: { span: 10 },
  },
];

export const formSchema: FormSchema[] = [
  {
    label: '主键',
    field: 'idx',
    component: 'Input',
    show: false,
  },
  {
    label: '学生姓名',
    field: 'name',
    component: 'Input',
  },
  {
    label: '学生卡号',
    field: 'stid',
    component: 'Input',
  },
  {
    label: '卡号硬件ID',
    field: 'cid',
    component: 'Input',
  },
  {
    label: '一卡通账户',
    field: 'account',
    component: 'Input',
  },
  {
    label: '身份证号',
    field: 'idcard',
    component: 'Input',
  },
  {
    label: '生效时间',
    field: 'stime',
    component: 'DatePicker',
    componentProps: {
      //日期格式化，页面上显示的值
      format: 'YYYY-MM-DD HH:mm:ss',
      //返回值格式化（绑定值的格式）
      valueFormat: 'YYYY-MM-DD HH:mm:ss',
      //是否显示今天按钮
      showToday: true,
      showTime: true,
    },
  },
  {
    label: '失效时间',
    field: 'etime',
    component: 'DatePicker',
    componentProps: {
      //日期格式化，页面上显示的值
      format: 'YYYY-MM-DD HH:mm:ss',
      //返回值格式化（绑定值的格式）
      valueFormat: 'YYYY-MM-DD HH:mm:ss',
      //是否显示今天按钮
      showToday: true,
      showTime: true,
    },
  },
  {
    label: '当前状态',
    field: 'state',
    component: 'RadioButtonGroup',
    defaultValue: 1,
    componentProps: {
      //options里面由一个一个的radio组成,支持disabled禁用
      options: [
        { label: '正常卡', value: 1 },
        { label: '特殊卡', value: 0 },
        { label: '黑名单', value: 2 },
        { label: '挂失卡', value: -2 },
        { label: '无效卡', value: -1 },
      ],
    },
  },
];
